其他
Entity Framework-Plus: 让 EF Core 如虎添翼
The following article is from Dotnet 工具箱 Author 工具箱
Entity Framework Plus
Entity Framework Plus 是一个用于增强 EF6 和 EF Core 的免费开源库。它对您的数据库上下文 DbContext 进行了扩展,包括过滤器、审核、缓存、批量删除、批量更新等。
功能特性
批量删除
使用 LINQ 直接删除实体,并需在上下文中加载实体。支持设置批处理大小来提高性能。
// 删除所有 2 年内不活动的用户
var date = DateTime.Now.AddYears(-2);
ctx.Users.Where(x => x.LastLoginDate < date)
.Delete();
// 使用 BatchSize 进行删除
var date = DateTime.Now.AddYears(-2);
ctx.Users.Where(x => x.LastLoginDate < date)
.Delete(x => x.BatchSize = 1000);
批量更新
// 更新所有两年内不活动的用户
var date = DateTime.Now.AddYears(-2);
ctx.Users.Where(x => x.LastLoginDate < date)
.Update(x => new User() { IsSoftDeleted = 1 });
查询过滤
下面的示例中,过滤了软删除记录
QueryFilterManager.Filter<Post>
(q => q.Where(x => !x.IsSoftDeleted));
var ctx = new EntitiesContext();
// SELECT * FROM Post WHERE IsSoftDeleted = false
var list = ctx.Posts.ToList();
查询缓存
查询的结果从缓存中返回,如果查询时没有缓存,会查询数据库并进行缓存。可以指定缓存策略和缓存标签来控制缓存过期。
// (EF5 | EF6) 2 个小时的查询缓存
var states = ctx.States.Where(x => x.IsActive).FromCache(DateTime.Now.AddHours(2));
// 两个小时的滑动过期
var options = new MemoryCacheEntryOptions() { SlidingExpiration = TimeSpan.FromHours(2)};
var states = ctx.States.Where(x => x.IsActive).FromCache(options);
项目地址
https://github.com/zzzprojects/EntityFramework-Plus
- EOF -
C#+Blazor 前后端分离快速开发框架,开箱即用10 微秒级别性能!C# 开发的离线IP地址库
看完本文有收获?请转发分享给更多人
推荐关注「DotNet」,提升.Net技能
点赞和在看就是最大的支持❤️